// pages/goods_list/index.js
import { request } from "../../request/index.js"
Page({
  data: {
    tabs: [
      {
        id:0,
        value: "综合",
        isActive: true
      },
      {
        id:1,
        value: "销量",
        isActive: false
      },
      {
        id:2,
        value: "价格",
        isActive: false
      }
    ],
    goodsList: []
  },
  // 接口要的参数
  QueryParams: {
    query: "",
    cid: "",
    pagenum: 1,
    pagesize: 10
  },
  // 总页数
  totalPages:1,
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.QueryParams.cid = options.cid||""
    this.QueryParams.query = options.query||""
    this.getGoodsList()
  },
  // 获取商品列表数据
  async getGoodsList () {
    const res = await request({url:"/goods/search",data:this.QueryParams})
    // 获取总条数
    const total = res.total
    // 计算总页数
    this.totalPages = Math.ceil(total/this.QueryParams.pagesize)
    // console.log(this.totalPages)
    this.setData({
      goodsList: [...this.data.goodsList,...res.goods]
    })

    // 关闭下拉刷新的窗口
    wx.stopPullDownRefresh()
  },
  // 标题点击事件 从子组件传递过来的
  handleTabsItemChange (e) {
    const {index} = e.detail
    let {tabs} = this.data
    tabs.forEach((v,i)=>i===index?v.isActive=true:v.isActive=false)
    this.setData({
      tabs
    })
  },
  // 页面上滑 滚动条触底事件
  onReachBottom () {
    // 判断还有没有下一页数据
    if (this.QueryParams.pagenum>=this.totalPages) {
      // 没有下一页了
      wx.showToast({
        title: '没有下一页了'
      })
    }else{
      this.QueryParams.pagenum++
      this.getGoodsList()
    }
  },
  // 下拉刷新事件
  onPullDownRefresh () {
    // 重置数据
    this.setData({
      goodsList: []
    })
    // 重置页面
    this.QueryParams.pagenum = 1
    // 发送请求
    this.getGoodsList()
  }
})